有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java使用BooleanQuery还是编写更多索引?

这样的类别树:

root_1
  sub_1
  sub_2
  ... to sub_20 

每个文档都有一个子类别(如sub_2)。现在,我只在lucene索引中写了sub_2

new NumericField("category",...).setIntValue(sub_2.getID());

我想获取所有root_1的文档,使用BooleanQuery(将sub_1合并到sub_20)在每个条目文档中搜索或写入其他类别:

new NumericField("category",...).setIntValue(sub_2.getID());
new NumericField("category",...).setIntValue(root_1.getID());//sub_2's ancestor category

哪个是更好的选择


共 (1) 个答案

  1. # 1 楼答案

    我将使用类别层次结构的路径枚举/杜威十进制表示。也就是说,不只是存储第一个根的第二个子级的“sub_2”,而是存储类似于“001.002”的内容

    要查找根目录及其所有子目录,您可以在“category:001*”上进行搜索

    要仅查找根的子级,您可以搜索“类别:001.*

    (另请参阅How to store tree data in a Lucene/Solr/Elasticsearch index or a NoSQL db?。)